-
Notifications
You must be signed in to change notification settings - Fork 156
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dynamic Config Resolver #459
base: main
Are you sure you want to change the base?
Dynamic Config Resolver #459
Conversation
|
||
@ParameterizedTest | ||
@MethodSource("getTestConfigs") | ||
public void testPrecedenceIsDynamicThenStaticPerRealmThenStaticGlobal(TestConfig testConfig) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What about catalog-level? I'd assume the catalog-level properties take precedence over everything, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Based on this it already should. I assumed there were tests already for that.
* integration with feature flag systems which are intended for fetching configs at runtime. | ||
*/ | ||
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "type") | ||
public interface DynamicFeatureConfigResolver extends Discoverable { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TBH, I feel that this type should be unnecessary. Unfortunately, we just added the featureConfiguration
field as a map, rather than having the DefaultConfigurationStore
instantiated and populated by Jackson during application startup. Now the configuration can't really change to add, e.g., a type
configuration key so that we could use different PolarisConfigurationStore
implementations. The PolarisConfigurationStore
interface was always intended to support dynamic implementations - which is why the PolarisCallContext
is part of the signature.
I'm just trying to figure out if there isn't a way to make the implementation swappable, while still supporting the backward-compatible configuration. I mean, there's no real harm in adding another interface, but it just feels unnecessary and the consequence of poor decision making earlier on. I hate the idea of that poor decision making having to follow us around forever.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another option would be to make the whole implementation swappable as you mentioned, which could be implemented in a backward compatible way: if a custom type is specified, use it, otherwise use the default. I don't think this change makes that impossible in the future. In fact, you can simply make DynamicFeatureConfigResolver implement the entire configuration store.
What are the things that need / depend on this change? |
Hey @snazy I'm not sure I understand the intent of the question. This is the only change I have planned regarding dynamic configs, as this provides the hook necessary for implementors. |
My question is: what/who needs this change? My overall concern is it's going beyond a "simple" implementation. Maybe I'm a bit blessed as I'm used to what Quarkus and all its extensions offer for configuration via Smallrye-Config, where such things (various config sources, dynamic configurations, encryption, etc etc) are rather just available. |
@snazy Snowflake is interested in the capability. This is pretty much the simplest and most flexible implementation possible. It can exist regardless of the framework as the implementation can fetch config from anywhere. Can you share an example of how you could inject dynamic, account-level config from a 3rd party in the Quarkus PR? |
The example is pretty easy:
Where
The rest is just smallrye-config setup and usage stuff - some starter information is here. Config sources do not have to be static - those can provide dynamic values - but that's up to the config source really. I'd really prefer an approach that leverages functionality that is proven to work in the wild for quite some time now, and with Quarkus there are already a lot of extensions that do provide "dynamic configuration" - for example this one or this one. Using already existing functionality is IMHO more efficient, think of #469, than writing some custom configuration framework. |
NB: you can take a look on #469 where we are using injected confict. Especially: https://github.com/jbonofre/polaris/blob/QUARKUS/polaris-service-quarkus/README.md#configuration |
I think this is a reasonable approach and I think this should address the concern of where we get the dynamic config. A Quarkus impl can use whatever the smallrye config structure internally, but we can't tie it to that. The |
I also would prefer this approach, as it is CDI-friendly. But I also think that, before diving head first on making things "dynamic", we should take some time to design a revamped
But the current On top of that, I always wondered why interface PolarisConfiguration {
boolean configX();
Optional<String> configY();
List<String> configZ();
} ... that each implementor would be free to implement their own way, we have: public class PolarisConfiguration<T> {
public static final PolarisConfiguration<Boolean> CONFIG_X = ...
public static final PolarisConfiguration<String> CONFIG_Y = ...
public static final PolarisConfiguration<List<String>> CONFIG_Z = ...
} ... which is a lot harder to extend, or to make "dynamic" or "layered". And involves many runtime casts that are error-prone, cf I would therefore suggest that we embrace the big picture and redesign |
This PR is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days. |
FYI, Quarkus has recently introduced a new extension that integrates Quarkus with Open Feature, a backend-agnostic feature flag library. Open Feature has support for Statsig, Unleash, flagd and a few others ( This is all bleeding edge for sure, but we may want to explore this approach as well, as opposed to implementing our own from scratch. |
Description
Introduces the notion of a
DynamicFeatureConfigResolver
, which can be used to dynamically resolvefeatureConfiguration
values at runtime. This is intended for integration with feature flag systems (Statsig, LaunchDarkly, etc) but this PR does not provide the implementations, rather just a hook to make it possible.Type of change
How Has This Been Tested?
Checklist: